<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>1外间距测试</title>
    <style>
        body {
            margin: 0; /*可以去掉body自带的外间距*/
        }
        .fu {
            background-color: rgba(255,255,0,.3);/*不透明度为0.3*/
            overflow: hidden;/*给父元素生成BFC结界 把首尾子元素超出的外间距包裹在内*/
        }
        .fu>div {/*选中父元素下的所有子级div*/
            width: 100px;
            height: 100px;
            background-color: rgba(0,0,255,.6);
            border: 2px solid #00f;
            color: #fff;
        }
        .z1 {
            margin-bottom: 30px;
            margin-top: 50px;/*第一个子元素的上外间距会超出父元素的范围*/
        }
        .z2 {
            margin-top: 50px;/*兄弟间在垂直方向上的外间距,取最大值显示*/
        }
        .z4 {
            margin-bottom: 50px;/*最后一个子元素的下外间距会超出父元素的范围*/
        }
        .z3 {
            /* 让块级元素在父元素中水平居中 上下0 左右auto自动计算为等值 */
            margin: 0 auto;
        }
        span {
            border: 2px solid #f00;
        }
        .s2 {
            /*行内元素垂直方向的外间距不生效,不要使用!*/
            margin:30px 20px;
        }
    </style>
</head>
<body>
<span>span1</span>
<span class="s2">span2</span>
<span>span3</span>

<!-- .fu>.z*4 -->
<div class="fu">
    <div class="z1">子元素div1</div>
    <div class="z2">子元素div2</div>
    <div class="z3">子元素div3</div>
    <div class="z4">子元素div4</div>
</div>

</body>
</html>